Open loop cyclostationarity based timing recovery for accelerated timing acquisition in frequency selective channels

ABSTRACT

An error between the rate f sym  at which data are received and the rate f s  at which the data are sampled in is determined by processing a received signal with a nonlinear operator, performing a DFT on the processed signal to produce a plurality of DFT bins each characterized by a respective frequency, determining a dominant spectral component k 0  from at least two of the DFT bins whose frequencies are substantially close to the frequency of the dominant spectral component k 0 , and determining the data rate f sym  from the dominant spectral component k 0 .

RELATED APPLICATIONS

[0001] The present application claims the benefit of Provisional Application Serial No. 60/336,071 filed on Oct. 25, 2001.

TECHNICAL FIELD OF THE INVENTION

[0002] The present invention relates to timing recovery in digital receivers.

BACKGROUND OF THE INVENTION

[0003] Digital receivers typically sample the received signal, and process these samples in order to perform a variety of functions. It is important in such receivers to sample the received signal at the instants when a data element such as a symbol is present. Accordingly, receivers recover the timing at which data elements are received and use this timing to control sampling of the received signal.

[0004] Timing recovery deals with finding the ideal sample times to recover the received symbols from a received signal. Mismatch between the transmitter and receiver clocks complicates the recovery process because slight differences between these clocks causes a signal to be sampled at the wrong times, contributing to intersymbol interference.

[0005] One popular technique for recovering timing in a receiver is known as the Gardner technique. FIG. 1 illustrates a waveform representing data that might be received at a receiver. In the limited case of FIG. 1, the data is +1 −1 −1 +1. This waveform assumes that the transmitted data is confined to a binary constellation containing only values of −1 and +1, although it can be shown that the Gardner technique works as well for larger constellations. As shown by FIG. 1, the received signal is sampled at two times the data rate.

[0006] The Gardner technique essentially forms a timing error according to b(a−c). As long as the sampling is exactly synchronized with respect to the received data, the quantity b(a−c) is zero. For example, in the case of a transition from +1 to −1 as shown in FIG. 1, b is zero so that the quantity b(a−c) is zero. In the case of no transition so that two adjacent bits have the same value such as −1 and −1 as shown in FIG. 2, b is no longer zero. However, a and c have the same value so that the quantity b(a−c) is again zero.

[0007] If the sampling timing is not exactly synchronized to the received data, the quantity b(a−c) is not zero but, instead, takes on a value that is a measure of how far off the sampling is from the optimal sampling instants. This value is the timing error and may be used to re-synchronize the sampler to the received data.

[0008] Although the Gardner technique works reasonably well in the case of white Gaussian noise such as electronic thermal noise or atmospheric noise, it does not work as well in the case of multi-path reception of the transmitted signal.

[0009] The present invention relates to the accurate recovery of timing even in the presence of multi-path reception of a transmitted signal.

SUMMARY OF THE INVENTION

[0010] In accordance with one aspect of the present invention, a method is provided to determine an error between the rate f_(sym) at which data are received and the rate f_(s) at which the data are sampled in a receiver. The method comprises the following: processing a received signal by a nonlinear operator; performing a DFT on the processed signal to produce a plurality of DFT bins each characterized by a respective frequency; determining a dominant spectral component k₀ from at least two of the DFT bins whose frequencies are substantially close to the frequency of the dominant spectral component k₀; and, determining the data rate f_(sym) from the dominant spectral component k₀.

[0011] In accordance with another aspect of the present invention, a method is provided to correct the sampling rate f_(s) of a receiver so that the sampling rate f_(s) matches the rate f_(sym) at which data are received by the receiver. The method comprises the following: processing a received signal by a nonlinear operator; performing a DFT on the processed signal to produce a plurality of DFT bins each characterized by a respective frequency; determining a dominant spectral component k₀ from two of the DFT bins whose frequencies are substantially close to the frequency of the dominant spectral component k₀; determining an error based on the dominant spectral component k₀, wherein the error indicates an offset between f_(s) and f_(sym); and, adjusting the sampling rate f_(s) to reduce the error.

[0012] In accordance with still another aspect of the present invention, a method is provided to determine a relationship between a sampling rate f_(s) at which a receiver samples received data and a data receive rate f_(sym) at which the data are received by the receiver. The method comprises the following: processing a received signal by a nonlinear operator; sampling the processed received signal to produce signal samples; performing a DFT on the signal samples to produce a plurality of DFT bins each characterized by a corresponding frequency; determining a dominant spectral component k₀ from two of the DFT bins whose corresponding frequencies are equal or closest to f_(sym); and, determining the relationship between the sampling rate f_(s) and the data receive rate f_(sym) based on the dominant spectral component k₀.

BRIEF DESCRIPTION OF THE DRAWINGS

[0013] These and other features and advantages will become more apparent from a detailed consideration of the invention when taken in conjunction with the drawings in which:

[0014]FIGS. 1 and 2 illustrate waveforms useful in explaining a prior art approach to the correction of the sampling rate in a receiver;

[0015]FIG. 3 illustrates an 8 VSB spectrum at baseband;

[0016]FIG. 4 illustrates a timing error detector according to an embodiment of the present invention;

[0017]FIG. 5 illustrates a DFT (Discrete Fourier Transform) of a received signal;

[0018]FIG. 6 illustrates a DFT of a squared received signal;

[0019]FIG. 7 illustrates a DFT of a received signal raised to the fourth power;

[0020]FIG. 8 illustrates an arrangement for correcting the sampling frequency of a receiver based on the timing error detected by the timing error detector shown in FIG. 4; and,

[0021]FIG. 9 illustrates a loop filter that can be used on the arrangement of FIG. 8.

DETAILED DESCRIPTION

[0022] While the timing estimator disclosed herein is equally applicable to other linear modulation techniques, the present invention is disclosed herein with particular reference to 8 VSB modulation, such as that currently employed in digital television. The 8 VSB signal is a linearly modulated 8-ary PAM signal with real-valued symbols b[k] and a complex pulse shape p_(v)(t). The transmitted signal may be expressed by the following equation: $\begin{matrix} {{x_{v}(t)} = {\sum\limits_{k}{{b\lbrack k\rbrack}{{p_{v}\left( {t - {kT}_{sym}} \right)}.}}}} & (1) \end{matrix}$

[0023] The symbols sent every T_(sym) seconds are assumed to be independent and identically distributed. These symbols are taken from the alphabet having the following amplitudes:

b[m]=(2m−9)d, for m=1,2, . . . ,8

[0024] where 2d is the distance between adjacent symbols. The 8 VSB pulse shape p_(v)(t) is the complex root raised cosine pulse shape whose spectrum is shown in FIG. 3.

[0025] The 8 VSB signal x_(v)(t) is passed through a channel denoted c(t) and is received at the receiver to yield a noisy signal according to the following equation:

r _(v)(t)=c(t)*x_(v)(t)+ν(t)  (2)

[0026] where * denotes convolution and ν(t) is the zero-mean complex additive white Gaussian noise with independent and identically distributed real and imaginary components, each with a variance σ_(n) ². In “all-digital” receivers, the received signal is, prior to matched filtering, oversampled by some multiple (such as two) of the nominal symbol rate f_(sym)=(1/T_(sym)) to give the digital signal r_(v)[n].

[0027] The cyclostationarity technique disclosed herein recovers information about the symbol rate by first passing the received signal through a non-linearity to detect a discrete spectral component corresponding to the symbol rate and then filtering or using some other technique to determine the frequency of the spectral component.

[0028] In one embodiment of the present invention, this non-linearity is squaring. Accordingly, the received signal represented by equation (2) is squared to produce the following equation: $\begin{matrix} \begin{matrix} {{r_{v}^{2}(t)} = \quad \left( {{{x_{v}(t)}*{c(t)}} + {\upsilon (t)}} \right)^{2}} \\ {= \quad {\left( {{x_{v}(t)}*{c(t)}} \right)^{2} + {2\quad {\upsilon (t)}\left( {{x_{v}(t)}*{c(t)}} \right)} + {v^{2}(t)}}} \end{matrix} & (3) \end{matrix}$

[0029] An interesting result of simply squaring the signal rather than squaring the magnitude of the signal is that the complex-valued noise averages to zero. This result means that the expected value of the noise, ε{v²(t)}, is zero. Moreover, because the noise is assumed zero-mean and independent of the data, the expected value of the cross terms in equation (3) is also zero. Therefore, taking the expected value removes all terms involving the noise v(t) according to the following equation:

ε{r _(v) ²(t)}=ε{(x _(v)(t)*c(t))²}  (4)

[0030] Combining equations (1) and (4) produces the following equation: $\begin{matrix} {{ɛ\left\{ {r_{v}^{2}(t)} \right\}} = {\sigma_{b}^{2}{\sum\limits_{k}{p_{c}^{2}\left( {t - {kT}_{sym}} \right)}}}} & (5) \end{matrix}$

[0031] where p_(c)(t)=p_(v)(t)*c(t)

[0032] Equation (5) describes a signal that is periodic with a period T_(sym). Therefore, equation (5) can be expressed as a Fourier series according to the following equation: $\begin{matrix} {{ɛ\left\{ {r_{v}^{2}(t)} \right\}} = {\sum\limits_{k}{c_{k}^{{j2}\quad \pi \quad {kf}_{sym}}}}} & (6) \end{matrix}$

[0033] where c_(k) are the Fourier coefficients.

[0034] For a band limited signal, squaring the signal doubles the bandwidth of the signal. For the baseband 8 VSB signal, the baseband spectrum extends from −0.31 MHz to 5.69 MHz. Thus, the squared signal has energy in the frequency interval from −0.62 MHz to 11.38 MHz. Because f_(sym)=10.72 MHz for the 8 VSB signal, all Fourier series coefficients are zero except c₀ and c₁.

[0035] While the relationship between the receiver's sampling rate f_(s) and the true symbol rate f_(sym) is not known precisely at the receiver, it is reasonable to assume that the receiver has a good initial estimate of the true symbol rate. Use of a crystal oscillator having an accuracy of ±100 parts per million (ppm) means that it can reasonably be assumed that the receiver can determine the symbol rate f_(sym) of the received signal relative to its own clock within ±100 ppm. Based on these assumptions, if a data signal has a symbol rate of 10 MHZ, the symbol rate is known within ±1000 Hz at the receiver. However, even this small offset can cause severe error performance over time unless this error is corrected.

[0036] In one embodiment of the present invention, the received signal is oversampled to produce samples r_(v)[n]. As shown in FIG. 4, the oversampled signal r_(v)[n] is supplied to a timing error detector 10 that includes a bandpass filter 12 operating at half the nominal symbol rate (f_(sym)/2). The bandpass filter 12 bandpass filters the oversampled signal r_(v)[n]. The impulse response of the bandpass filter 12, for example, may be given by the following equation: $\begin{matrix} {{h_{bpf}\lbrack n\rbrack} = {{\cos \left( {\pi \frac{n}{2\quad K}} \right)}{\cos \left( {\pi \frac{n}{U_{os}}} \right)}}} & (7) \end{matrix}$

[0037] where K is the filter length and U_(OS) is the oversampling factor.

[0038] The resulting signal r_(bpf)[n] is passed through a non-linear operator 14 that imposes a non-linear operation, such as squaring, on the signal r_(bpf)[n] in order to boost the spectral line at the digital frequency corresponding to the symbol rate f_(sym) relative to the other spectral lines. For example, FIG. 5 shown a DFT of a received signal without the non-linear operation. The symbol rate f_(sym) is buried among the other frequency components of the received signal and cannot be readily distinguished. FIG. 6 shows the effects on the DFT of squaring the received signal samples. The symbol rate f_(sym) rises above the other frequency components and, thereby, is more readily distinguished. As also can be seen by comparing FIGS. 5 and 6, the bandwidth has doubled when the samples of the received signal are squared.

[0039] The non-linearity is preferably chosen with the nominal sampling rate in mind so that the signal's spectrum is not aliased near the symbol rate f_(sym). For an 8 VSB signal that is squared, sampling at twice the nominal symbol rate is enough to prevent aliasing of the squared signal.

[0040] The signal x[n] resulting from the non-linear operator 14 is modeled over a small frequency interval around the true symbol rate as a single complex exponential plus white noise according to the following equation:

x[n]=αz[n]+v[n]  (7)

[0041] where $\begin{matrix} {{z\lbrack n\rbrack} = ^{j\frac{2\quad \pi \quad k_{0}n}{N}}} & (8) \end{matrix}$

[0042] where α is a complex scalar, and where v[n] is the noise component. It is then possible to compute two Discrete Fourier Transform (DFT) values {tilde over (Z)}(k) and {tilde over (Z)}(k+1) near the nominal value of k₀ that corresponds to the rate f_(sym) at which data is received, to determine k₀ from these values, and to determine the relationship between f_(sym) and f_(s) from k₀. Subspace based averaging may be used to determine these values such that the effect of noise is minimized.

[0043] Accordingly, a timing error estimator 16 performs a DFT on x[n]. A conjugate centrosymmetrized version of the kth bin of the resulting N-point DFT is given by the following equation: $\begin{matrix} {{\overset{\sim}{X}(k)} = {\sum\limits_{n = 0}^{N - 1}{{x\lbrack n\rbrack}^{{- j}\frac{2\quad \pi \quad k}{N}{({n - \frac{N - 1}{2}})}}}}} & (9) \end{matrix}$

[0044] where x[n] are the received signal samples. Equation (9) can be re-written as a product of vectors according to the following equation:

{tilde over (X)}(k)={tilde over (w)}_(k) ^(H)x  (10)

[0045] where $\begin{matrix} {{\overset{\sim}{w}}_{k}^{H} = {\left\lbrack {^{j\frac{2\quad \pi \quad k}{N}{(\frac{N - 1}{2})}}^{j\frac{2\quad \pi \quad k}{N}{(\frac{N - 3}{2})}}\cdots \quad ^{{- j}\frac{2\quad \pi \quad k}{N}{(\frac{N - 1}{2})}}} \right\rbrack \in C^{N}}} & (11) \end{matrix}$

[0046] and where

x=[x[0]x[1]. . . x[N−1]]^(T) εC ^(N)  (12)

[0047] C^(N) represents the N dimensional complex vector space comprising complex vectors each of length N. The rotated DFT vector {tilde over (w)}_(k) is termed conjugate centrosymmetric because its mth element is equal to the conjugate of its (N-m)th element for m=0, . . . , N−1. {tilde over (X)}(k) may be found by first finding the DFT value X(k) and by then post multiplying this value by $^{j\frac{2\quad \pi \quad k}{N}{(\frac{N - 1}{2})}}.$

[0048] If z[n] is the single complex exponential in equation (8), then the kth bin of the conjugate centrosymmetrized DFT of z[n] evaluated at DFT bin k is given by the following equation: $\begin{matrix} {{\overset{\sim}{Z}(k)} = {\frac{\sin \quad \left( {\pi \left( {k - k_{0}} \right)} \right)}{\sin \left( {\frac{\pi}{N}\left( {k - k_{0}} \right)} \right)}^{j\frac{2\quad \pi \quad k_{0}}{N}{(\frac{N - 1}{2})}}}} & (13) \end{matrix}$

[0049] and the conjugate centrosymmetrized DFT of z[n] evaluated at DFT bin k+1 is given by the following equation: $\begin{matrix} {{\overset{\sim}{Z}\left( {k + 1} \right)} = {\frac{\sin \left( {\pi \left( {k + 1 - k_{0}} \right)} \right)}{\sin \left( {\frac{\pi}{N}\left( {k + 1 - k_{0}} \right)} \right)}^{j\frac{2\quad \pi \quad k_{0}}{N}{(\frac{N - 1}{2})}}}} & (14) \end{matrix}$

[0050] Using the trigonometric identity sin(A+B)=sin(A)cos(B)+cos(A)sin(B), the numerator of equation (14) becomes −sin(π(k−k₀)). Therefore, dividing equation (13) by equation (14) yields the following equation: $\begin{matrix} {\frac{\overset{\sim}{Z}(k)}{\overset{\sim}{Z}\left( {k + 1} \right)} = {- \frac{\sin \left( {\frac{\pi}{N}\left( {k + 1 - k_{0}} \right)} \right)}{\sin \left( {\frac{\pi}{N}\left( {k - k_{0}} \right)} \right)}}} & (15) \end{matrix}$

[0051] Applying the trigonometric identity given above to equation (15) produces the following equation: $\begin{matrix} {k_{0} = {\frac{N}{\pi}{\tan^{- 1}\left( \frac{{{\overset{\sim}{Z}(k)}{\sin \left( {\frac{\pi}{N}k} \right)}} + {{\overset{\sim}{Z}\left( {k + 1} \right)}{\sin \left( {\frac{\pi}{N}\left( {k + 1} \right)} \right)}}}{{{\overset{\sim}{Z}(k)}{\cos \left( {\frac{\pi}{N}k} \right)}} + {{\overset{\sim}{Z}\left( {k + 1} \right)}{\cos \left( {\frac{\pi}{N}\left( {k + 1} \right)} \right)}}} \right)}}} & (16) \end{matrix}$

[0052] Based on k₀, the true symbol rate, i.e., the symbol rate of the received data, can be determined from the following equation: $\begin{matrix} {f_{sym} = {\frac{k_{0}}{N}f_{s}}} & (17) \end{matrix}$

[0053] where N is the number of bins in the DFT and f_(s) is the sampling frequency of the receiver.

[0054] The relationship between f_(sym) and f_(s) should ideally be the design relationship. For example, if the sampling rate is nominally set at twice the symbol rate used by the transmitter, then ideally f_(sym)=f_(s)/2. If the actual symbol rate of the received data, as determined by equations (16) and (17), and f_(s) do not have this ideal relationship, then the sampling rate of the receiver is adjusted until the ideal relationship is achieved.

[0055] The timing error estimator 16 can also determine the timing error by subtracting k₀ from k. This timing error may be used to appropriately adjust the sampling frequency of the receiver in order to correctly sample the received signal.

[0056] As discussed above, the non-linear operator 14 may be arranged to square the signal from the bandpass filter 12. Instead, other non-linearities can be imposed on the received signal. For example, the received signal may be raised to the fourth power, i.e., (r_(v)[n])⁴. FIG. 7 shows the effects on the DFT of raising the received signal samples to the fourth power. The symbol rate f_(sym) rises even more above the other frequency components and, thereby, is even more readily distinguished than is the case of simply squaring the samples. As also can be seen by comparing FIGS. 5 and 7, the bandwidth has quadrupled when the samples of the received signal are raised to the fourth power. For an 8 VSB signal that is raised to the fourth power, sampling at four times the nominal symbol rate is enough to prevent aliasing of the signal raised to the fourth power. When the non-linear operator 14 raises the received signal samples to the fourth power, the bandpass filter 12 becomes unnecessary.

[0057] It is preferable for the process described above that values for N and k be chosen so that k<k₀<k+1 and so that N<fs/(2Δf) where Δf is the tolerance of the a priori estimate. For example, in the case where the samples are raised to the fourth power so that the sampling is at about four times the symbol rate, N can be set at 4096, and k can be set at 1024 representing the nominal symbol rate f_(sym). The frequency associated with bin k+1 is the next higher frequency. The bin k−1 can be used instead of the bin k+1.

[0058]FIG. 8 shows an arrangement for correcting the sampling frequency of the receiver. The received signal is re-sampled by a re-sampler 22 that receives the samples from an upstream sampler, that effectively reconstructs an analog signal from the samples, and that re-samples the reconstructed analog signal in response to a sampling frequency supplied by a numerically controlled oscillator 24. The samples at the output of the re-sampler 22 are processed by a timing error estimator 26 to detect the error between f_(s) and f_(sym) as described above, and this error is filtered by a loop filter 28. The filtered error from the loop filter 28 then controls the numerically controlled oscillator 24 to produce the correct sampling frequency for the re-sampler 22. A matched filter may be located in the output of the re-sampler 22 upstream of the timing error estimator 26, or the matched filter may instead be located upstream of the re-sampler 22.

[0059]FIG. 9 shows an example of a loop filter 40 that can be used for the loop filter 28 of FIG. 8. The loop filter 40 is a low pass filter that smoothes the error provided by the timing error estimator 26. The smoothed error is denoted in FIG. 9 as l[n]. The quantities α₁ and α₂ are constants.

[0060] If the noise component v[n] in x[n] is removed, {tilde over (X)}(k,n) and {tilde over (X)}(k+l,n) can be used in equation (16) in place of {tilde over (Z)}(k) and {tilde over (Z)}(k+1) because multiplication by a scalar has no effect on equation (16). One way of removing the noise component in x[n] is to perform subspace-based, or eigenvalue-based, averaging in the frequency domain.

[0061] Let {tilde over (X)}(k,n) and {tilde over (X)}(k+1,n) be conjugate centrosymmetric N point DFT values of {x[n−N+1], . . . , x[n]} at frequency bins k and k+1, respectively. These DFT values can be grouped as a vector X=[{tilde over (X)}(k,n){tilde over (X)}(k+1,n)]^(T). Then, the real-valued auto-correlation matrix R_(xx) of the received signal is simply the following expected value: ε{X[n]X^(H)[n]. This matrix has the following form: ${{Re}\left\{ {{\hat{R}}_{xx}\lbrack n\rbrack} \right\}} = \begin{bmatrix} a & b \\ c & d \end{bmatrix}$

[0062] The eigenvectors associated with this matrix have the following form: $e_{i} = {{{\varsigma \begin{bmatrix} \frac{\lambda_{i} - d}{c} & 1 \end{bmatrix}}^{T}\varsigma} \in C^{l}}$ $e_{i} = {\xi\left\lbrack \begin{matrix} \frac{b}{\lambda_{1} - a} & {{\left. 1 \right\rbrack^{T}\xi} \in C^{l}} \end{matrix} \right.}$

[0063] where λ_(l) are eigenvalues given by the following equation: $\lambda_{i} = \frac{a + {d \pm \sqrt{\left( {a - d} \right)^{2} + {4{bc}}}}}{2}$

[0064] The eigenvector associated with the largest eigenvalue of the real part of the sample correlation matrix {circumflex over (R)}_(xx)[n] is a multiple of Z=[{tilde over (Z)}(k) {tilde over (Z)}(k+1)]^(T). Therefore, these values of {tilde over (Z)}[k] and {tilde over (Z)}[k+1] can be derived from this eigenvector and used in equation (16) to compute k₀ which can be used in equation (17) to determine the relationship between f_(s) and f_(sym).

[0065] Because R_(xx) is real valued, only the real part of the vector product X[n]X^(H)[n] need be included when forming the sample correlation matrix. Because {circumflex over (R)}_(xx)[n] is

[0066] a 2×2 matrix, a simple closed form expression is available for the eigenvectors.

[0067] The first DFT values {tilde over (X)}(k,N−1) and {tilde over (X)}(k+1,N−1) may be computed gradually (without the need to store or compute all of the twiddle factors ${w_{N}^{nk} = ^{{- j}\frac{2\quad \pi \quad k\quad n}{N}}},$

[0068] n=0, . . . , N−1) using the well known Goertzel algorithm. Subsequent values of {tilde over (X)}(k,n) and {tilde over (X)}(k+1,n) for n>N−1 may be found recursively. If X(k,n) is the kth bin of the N point DFT of the current and past N−1 values of x[n], then X(k,n) is given by the following equation: $\begin{matrix} {{X\left( {k,n} \right)} = {\sum\limits_{m = 0}^{N - 1}{{x\left\lbrack {m + n - \left( {N - 1} \right)} \right\rbrack}^{{- {j2}}\quad \pi \quad k\quad \frac{m}{N}}}}} & (18) \end{matrix}$

[0069] and X(k,n) may be expressed in terms of X(k,n−1) according to the following equation: $\begin{matrix} \begin{matrix} {{X\left( {k,n} \right)} = \quad {{\left( {{X\left( {k,{n - 1}} \right)} - {x\left\lbrack {n - N} \right\rbrack}} \right)^{j2\quad \pi \quad \frac{k}{N}}} +}} \\ {\quad {{x\lbrack n\rbrack}^{{- j}2\pi \quad \frac{k{({N - 1})}}{N}}}} \end{matrix} & (19) \end{matrix}$

[0070] for n>N−1. Use of equation (19) requires only two complex multiplications and two additions, which is a significant computational savings over equation (18).

[0071] Furthermore, when k is an integer, equation (19) simplifies even more and requires only one complex multiplication and two additions according to the following equation: ${X\left\lbrack {k,n} \right\rbrack} = {\left( {{X\left\lbrack {k,{n - 1}} \right\rbrack} - {x\left\lbrack {n - N} \right\rbrack} + {x\lbrack n\rbrack}} \right)^{j\frac{2\quad \pi \quad k}{N}}}$

[0072] Accordingly, when averaging is used as described above, as each new sample is received, the sample is passed through the non-linear operation. Two conjugate centrosymmetric DFT values are found using the current sample and the previous N−1 samples. These values are used to update the real part of the sample correlation matrix, and the eigenvector having the largest eigenvalue is extracted to give a scaled estimate of {tilde over (Z)}(k) and {tilde over (Z)}(k+1). These values are used as per equations (16) and (17) to determine the symbol frequency of the received data.

[0073] Modifications of the present invention will occur to those practicing in the art of the present invention. Accordingly, the description of the present invention is to be construed as illustrative only and is for the purpose of teaching those skilled in the art the best mode of carrying out the invention. The details may be varied substantially without departing from the spirit of the invention, and the exclusive use of all modifications which are within the scope of the appended claims is reserved. 

We claim:
 1. A method for determining an error between the rate f_(sym) at which data are received and the rate f_(s) at which the data are sampled in a receiver comprising: processing a received signal by a nonlinear operator; performing a DFT on the processed signal to produce a plurality of DFT bins each characterized by a respective frequency; determining a dominant spectral component k₀ from at least two of the DFT bins whose frequencies are substantially close to the frequency of the dominant spectral component k₀; and, determining the data rate f_(sym) from the dominant spectral component k₀.
 2. The method of claim 1 wherein the processing of the received signal by a nonlinear operator comprises squaring the received signal.
 3. The method of claim 2 wherein the processing of the received signal comprises sampling the received signal at about twice the rate at which the data are received.
 4. The method of claim 1 wherein the processing of the received signal by a nonlinear operator comprises raising the received signal to the fourth power.
 5. The method of claim 4 wherein the processing of the received signal comprises sampling the received signal at about four times the rate at which the data are received.
 6. The method of claim 1 wherein the processing of a received signal by a nonlinear operator comprises sampling the received signal at the sampling rate f_(s) and processing the received signal samples by the nonlinear operator, and wherein the determining of a dominant spectral component k₀ comprises determining the dominant spectral component k₀ according to the following equation: $k_{0} = {\frac{N}{\pi}{\tan^{- 1}\left( \frac{{{\overset{\sim}{Z}(k)}{\sin \left( {\frac{\pi}{N}k} \right)}} + {{\overset{\sim}{Z}\left( {k + 1} \right)}{\sin \left( {\frac{\pi}{N}\left( {k + 1} \right)} \right)}}}{{{\overset{\sim}{Z}(k)}{\cos \left( {\frac{\pi}{N}k} \right)}} + {{\overset{\sim}{Z}\left( {k + 1} \right)}{\cos \left( {\frac{\pi}{N}\left( {k + 1} \right)} \right)}}} \right)}}$

wherein N comprises the number of points in the DFT, k and k+1 comprise the DFT bins whose frequencies are substantially close to the frequency of the dominant spectral component k₀, and {tilde over (Z)}(k) and {tilde over (Z)}(k+1) represent the energy in the bins k and k+1.
 7. The method of claim 6 wherein the determining of the error comprises determining a relationship between the sampling rate f_(s) and the data rate f_(sym) based on the dominant spectral component k₀.
 8. The method of claim 7 wherein the relationship comprises f_(sym)=(k₀/N)f_(s).
 9. The method of claim 8 wherein the processing of the received signal by a nonlinear operator comprises squaring the received signal.
 10. The method of claim 9 wherein the sampling of the received signal comprises sampling the received signal at about twice the rate at which the data are received.
 11. The method of claim 8 wherein the processing of the received signal by a nonlinear operator comprises raising the received signal to the fourth power.
 12. The method of claim 11 wherein the sampling of the received signal comprises sampling the received signal at about four times the rate at which the data are received.
 13. The method of claim 1 wherein the determining of a dominant spectral component k₀ of the processed received signal comprises: determining the autocorrelation of the received signal; selecting an eigenvector of the autocorrelation having the largest eigenvalue; and, determining the dominant spectral component k₀ based on the selected eigenvector.
 14. The method of claim 1 wherein the determining of a dominant spectral component k₀ of the processed received signal comprises determining the dominant spectral component k₀ based on subspace based averaging.
 15. A method for correcting the sampling rate f_(s) of a receiver so that the sampling rate f_(s) matches the rate f_(sym) at which data are received by the receiver, the method comprising: processing a received signal by a nonlinear operator; performing a DFT on the processed signal to produce a plurality of DFT bins each characterized by a respective frequency; determining a dominant spectral component k₀ from two of the DFT bins whose frequencies are substantially close to the frequency of the dominant spectral component k₀; determining an error based on the dominant spectral component k₀, wherein the error indicates an offset between f_(s) and f_(sym); and, adjusting the sampling rate f_(s) to reduce the error.
 16. The method of claim 15 wherein the processing of the received signal by a nonlinear operator comprises squaring the received signal.
 17. The method of claim 16 wherein the processing of the received signal comprises sampling the received signal at about twice the rate at which the data are received.
 18. The method of claim 15 wherein the processing of the received signal by a nonlinear operator comprises raising the received signal to the fourth power.
 19. The method of claim 18 wherein the processing of the received signal comprises sampling the received signal at about four times the rate at which the data are received.
 20. The method of claim 15 wherein the processing of a received signal by a nonlinear operator comprises sampling the received signal at the sampling rate f_(s) and processing the received signal samples by the nonlinear operator, and wherein the determining of a dominant spectral component k₀ comprises determining the dominant spectral component k₀ according to the following equation: $k_{0} = {\frac{N}{\pi}{\tan^{- 1}\left( \frac{{{\overset{\sim}{Z}(k)}{\sin \left( {\frac{\pi}{N}k} \right)}} + {{\overset{\sim}{Z}\left( {k + 1} \right)}{\sin \left( {\frac{\pi}{N}\left( {k + 1} \right)} \right)}}}{{{\overset{\sim}{Z}(k)}{\cos \left( {\frac{\pi}{N}k} \right)}} + {{\overset{\sim}{Z}\left( {k + 1} \right)}{\cos \left( {\frac{\pi}{N}\left( {k + 1} \right)} \right)}}} \right)}}$

wherein N comprises the number of points in the DFT, k and k+1 comprise the DFT bins whose frequencies are substantially close to the frequency of the dominant spectral component k₀, and {tilde over (Z)}(k) and {tilde over (Z)}(k+1) represent the energy in the bins k and k+1.
 21. The method of claim 20 wherein the determining of the error comprises determining a relationship between the sampling rate f_(s) and the data rate f_(sym) based on the dominant spectral component k₀.
 22. The method of claim 21 wherein the relationship comprises f_(sym)=(k₀/N) f_(s).
 23. The method of claim 20 wherein the processing of the received signal by a nonlinear operator comprises squaring the received signal.
 24. The method of claim 23 wherein the sampling of the received signal comprises sampling the received signal at about twice the rate at which the data are received.
 25. The method of claim 20 wherein the processing of the received signal by a nonlinear operator comprises raising the received signal to the fourth power.
 26. The method of claim 25 wherein the sampling of the received signal comprises sampling the received signal at about four times the rate at which the data are received.
 27. The method of claim 15 wherein the determining of a dominant spectral component k₀ of the processed received signal comprises: determining the autocorrelation of the received signal; selecting an eigenvector of the autocorrelation having the largest eigenvalue; and, determining the dominant spectral component k₀ based on the selected eigenvector.
 28. The method of claim 15 wherein the determining of a dominant spectral component k₀ of the processed received signal comprises determining the dominant spectral component k₀ based on subspace based averaging.
 29. The method of claim 15 wherein the adjusting of the sampling rate f_(s) to reduce the error comprises; loop filtering the error; adjusting the frequency of a numerically controlled oscillator; and, resampling the received signal based on the adjusted frequency.
 30. A method for determining a relationship between a sampling rate f_(s) at which a receiver samples received data and a data receive rate f_(sym) at which the data are received by the receiver, the method comprising: processing a received signal by a nonlinear operator; sampling the processed received signal to produce signal samples; performing a DFT on the signal samples to produce a plurality of DFT bins each characterized by a corresponding frequency; determining a dominant spectral component k₀ from two of the DFT bins whose corresponding frequencies are equal or closest to f_(sym); and, determining the relationship between the sampling rate f_(s) and the data receive rate f_(sym) based on the dominant spectral component k₀.
 31. The method of claim 30 wherein the relationship comprises f_(sym)=(k₀/N)f_(s), and wherein N comprises the number of points in the DFT.
 32. The method of claim 31 wherein the determining of a dominant spectral component k₀ comprises evaluating the DFT at bin k, evaluating the DFT at bin k+1, and determining the dominant spectral component k₀ based on the evaluations, and wherein k≦k₀≦k+1.
 33. The method of claim 32 wherein the processing of the received signal by a nonlinear operator comprises squaring the received signal.
 34. The method of claim 33 wherein f_(s)=2f_(sym).
 35. The method of claim 32 wherein the processing of the received signal by a nonlinear operator comprises raising the received signal to the fourth power.
 36. The method of claim 35 wherein f_(s)=4f_(sym).
 37. The method of claim 32 wherein the evaluating of the DFT at bin k and the evaluating the DFT at bin k+1 comprises: determining the autocorrelation of the received signal; selecting an eigenvector of the autocorrelation having the largest eigenvalue; and, determining the dominant spectral component k₀ based on the selected eigenvector.
 38. The method of claim 32 wherein the evaluating of the DFT at bin k and the evaluating the DFT at bin k+1 comprises determining the dominant spectral component k₀ based on subspace based averaging.
 39. The method of claim 30 wherein the processing of the received signal by a nonlinear operator comprises squaring the received signal.
 40. The method of claim 39 wherein f_(s)=2f_(sym).
 41. The method of claim 30 wherein the processing of the received signal by a nonlinear operator comprises raising the received signal to the fourth power.
 42. The method of claim 41 wherein f_(s)=4f_(sym). 